## AN10026\_1

Interfacing ISPI 160x to Motorola<sup>®</sup> DragonBall<sup>TM</sup> EZ RISC Processor

Semiconductors

# Application Note

### **Rev.** 1.0

| Revision History: |              |               |           |  |  |  |  |
|-------------------|--------------|---------------|-----------|--|--|--|--|
| Version           | Date         | Descriptions  | Author    |  |  |  |  |
| 1.0               | January 2003 | First release | Jason Ong |  |  |  |  |

**Note**: ISP1160x denotes any Philips embedded USB host controller whose name starts with 'ISP1160'; this includes ISP1160A, ISP1160A1, and any future derivatives.

We welcome your feedback. Send it to wired.support@philips.com.

Philips Semiconductors - Asia Product Innovation Centre Visit <u>www.semiconductors.philips.com/buses/usb</u> or <u>www.flexiusb.com</u>



January 2003

This is a legal agreement between you (either an individual or an entity) and Philips Semiconductors. By accepting this product, you indicate your agreement to the disclaimer specified as follows:

### DISCLAIMER

PRODUCT IS DEEMED ACCEPTED BY RECIPIENT. THE PRODUCT IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, PHILIPS SEMICONDUCTORS FURTHER DISCLAIMS ALL WARRANTIES, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANT ABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT. THE ENTIRE RISK ARISING OUT OF THE USE OR PERFORMANCE OF THE PRODUCT AND DOCUMENTATION REMAINS WITH THE RECIPIENT. TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, IN NO EVENT SHALL PHILIPS SEMICONDUCTORS OR ITS SUPPLIERS BE LIABLE FOR ANY CONSEQUENTIAL, INCIDENTAL, DIRECT, INDIRECT, SPECIAL, PUNITIVE, OR OTHER DAMAGES WHATSOEVER (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION, LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING OUT OF THIS AGREEMENT OR THE USE OF OR INABILITY TO USE THE PRODUCT, EVEN IF PHILIPS SEMICONDUCTORS HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

## CONTENTS

| Ι. | OVERVIEW                                          | .4  |
|----|---------------------------------------------------|-----|
| 2. | ISPI160X PROCESSOR INTERFACE SIGNALS              | .4  |
| 3. | MOTOROLA DRAGONBALL EZ                            | .4  |
| 4. | CONSIDERATIONS IN TIMING DIAGRAMS AND WAIT STATES | . 5 |
| 5. | USING INTERRUPTS                                  | .7  |
| 6. | SUSPEND AND RESUME                                | .7  |
| 7. | SCHEMATIC DIAGRAM                                 | . 8 |
| 8. | REFERENCES                                        | 10  |

### **FIGURES**

| Figur | e 4-1: Programmed | Interface Timing | (16-bit Read/Write | )6 |
|-------|-------------------|------------------|--------------------|----|
|       |                   |                  | (                  |    |

The names of actual companies and products mentioned herein may be the trademarks of their respective owners. All other names, products, and trademarks are the property of their respective owners.

**Note**: ISP1160x denotes any Philips embedded USB host controller whose name starts with 'ISP1160'; this includes ISP1160A, ISP1160A1, and any future derivatives.

#### I. Overview

When ISP1160x is integrated into a personal digital assistant (PDA) or handheld personal computer (HPC), it is usually connected to the external bus interface of a RISC processor. This application note deals with the critical issues in ISP1160x embedded design, using the Motorola<sup>®</sup> DragonBall<sup>™</sup> EZ RISC processor as a concrete example.

#### 2. ISPII60x Processor Interface Signals

The ISP1160x processor bus interface is designed for a simple direct connection with a RISC processor. The data transfer can be done in the programmed I/O (PIO) or direct memory access (DMA) mode. The estimated maximum data transfer rate on ISP1160x's generic processor bus is approximately 15 Mbyte/s. This is based on an ISP1160x internal clock frequency value of 48 MHz. To achieve the maximum data transfer rate on the host processor bus, ISP1160x contains a ping pong structured RAM that allows alternative access from the RISC processor or from the internal Host Controller. The Host Controller uses 2 kbytes of the ping memory and 2 kbytes of the pong memory in its allocated memory.

The main ISP1160x signals you should take into consideration for connecting to a Motorola DragonBall EZ RISC processor are:

- A 16-bit data bus (D[15:0]) for ISP1160x, which is "little endian" compatible.
- An address line (A0) necessary for complete addressing of the ISPI 160x internal registers:
  - A0 = 0—Selects the Data Port of the Host Controller
  - A0 = I—Selects the Command Port of the Host Controller
- One  $\overline{\text{CS}}$  line used to select ISP1160x in a certain address range of the host system. This input signal is active LOW.
- $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  are common read and write signals. These signals are active LOW.
- A DMA channel standard control lines: DREQ, <u>DACK</u> and EOT. Since the DragonBall EZ processor does not contain a DMA controller, these signals will not be used in a minimal hardware implementation.
- An interrupt line INTI, which has programmable level/edge and polarity (active HIGH or LOW).
- The CLKOUT signal has a maximum value of 48 MHz.
- The  $\overline{\text{RESET}}$  signal is active LOW.

#### 3. Motorola DragonBall EZ

Motorola MC 68EZ328, also called DragonBall EZ, is a processor from the second generation of the DragonBall EZ family. The MC68EZ328 combines a Motorola MC68EC000 processor with intelligent peripheral modules and typical system interface logic. The operating frequency of this processor is 16 MHz, obtained by an internal PLL, which accepts as input a 32.768 kHz crystal, oscillator or a clock signal.

The main internal blocks of the DragonBall-EZ processor to consider when analyzing the bus interface, on which ISPI 160x is connected, are as follows:

- The 8-bit or 16-bit 68000-bus interface block.
- The clock synthesizer and power control block.
- The chip-select generation block.
- The interrupt controller.

The DragonBall-EZ processor generates eight programmable general-purpose chip-select signals, which are arranged in four groups of two (CSA[1:0], CSB[1:0], CSC[1:0] and CSD[1:0]). Each chip-select block allows several features to be selected, which may be specific to the devices connected to each selected area:

- Bus size: 8 bits or 16 bits can be independently selected for each area. The default setting corresponds to a 16-bit bus size.
- Number of wait states inserted in a bus cycle can be set from zero to six.
- Each area selected by a CSn can be defined as read-only or read/write access.
- Different types of memory are supported for an area selected by a certain CSn: DRAM, ROM, SRAM and Flash memory.
- The size of any memory area selected by a Chip-Select signal can be selected from a set of predefined ranges (32 kbytes, 64 kbytes, 128 kbytes, 256 kbytes, 512 kbytes, 1 Mbytes, 2 Mbytes and 4 Mbytes).

For a CSn signal to operate correctly, you must program the "Chip-Select Group Base Address Registers" and the "Chip Select Registers", accordingly.

#### 4. Considerations in Timing Diagrams and WAIT states

The following is a short study of ISP1160x timing diagrams.

According to the ISP1160x datasheet specifications, a read operation requires the following timing parameters (the requirements of the write operation are similar); see Figure 4-1:

- $t_{RL}$  = 33 ns ( $\overline{RD}$  LOW pulse width—minimal value ISP1 160x requires),
- $t_{RHRL}$  = 110 ns ( $\overline{RD}$  HIGH to next  $\overline{RD}$  LOW—minimal value ISP1160x requires) and
- $t_{RHDZ}$  = 3 ns ( $\overline{RD}$  hold time, minimal value that can be expected from ISPI 160x).
- $t_{RC}$  = 143 ns (will result as a sum of  $t_{RL}$  and  $t_{RHRI}$ )
- $t_{sHSL}$  = 300 ns (first  $\overline{RD}/\overline{WR}$  after command).

For a detailed analysis of a timing diagram, consider the access of an ISP1160x internal register (for example, the Control Register of the Host Controller). It requires two phases: writing the address (index) of the selected register into the Command Port; then only data transfer access (RD/WR) may take place.

Note: The index of each register differs according to whether it is a RD or a WR operation.



Figure 4-1: Programmed Interface Timing (16-bit Read/Write)

When the ISP1160x connection area is defined as SRAM, ISP1160x will operate correctly for a bus clock CKIO = 33 MHz. Timing measurements show that inserting wait-states in the standard bus cycles of DragonBall EZ is unnecessary. Nevertheless, we will describe wait-state insertion, to cater for cases when faster bus cycles are used for accessing ISP1160x.

Wait states insertion can be implemented through hardware or software. Both solutions will delay the rising edge of  $\overline{\text{RD}}$  or  $\overline{\text{WR}}$  to the next CKIO cycle and will determine an elongation of the  $\overline{\text{RD}}$  or  $\overline{\text{WR}}$  LOW pulse that can be calculated as:

 $t_w = W \times T(CKIO);$  where: (W) is the number of wait states desired

T(CKIO) is the cycle length of CKIO.

**Note**: the value of  $t_{RHRL}$  will not be modified by the number of wait states inserted by any of the solutions mentioned earlier. The value of this parameter must be calculated and correctly adjusted according to the number and length of instructions executed by the DragonBall EZ processor between two successive accesses to ISP1160x. The "software solution" for wait-state insertion in a bus cycle is simple and is preferred in a minimal configuration, if additional wait states are necessary.

#### 5. Using Interrupts

ISPI 160x generates an interrupt on the INT pin. This INT signal can be directly connected to any available IRQ signal of the DragonBall processor. ISPI 160x's INT can be programmed as active on level or edge and HIGH or LOW, as specified in the *HcHardwareConfiguration* register.

#### 6. Suspend and Resume

You can enable ISP1160x to enter the Reset, Resume, Operational and Suspend functional states by programming the *HcControl* register of the Host Controller.

Another way to wake up ISPI 160x from the suspend mode is to use the input signals H\_WAKEUP (for the Host Controller). Monitoring the H\_SUSPEND pin for the host status can determine ISPI 160x's actual status, without having to access the internal status registers.

ISP1160x may wake up when its  $\overline{CS}$  input signal becomes active.

#### 7. Schematic Diagram

The schematic diagram on the following page shows ISPI 160x connected to a Motorola DragonBall EZ processor, in a minimal hardware configuration. For a more detailed description of the connection of ISPI 160x to a RISC processor and a study of each category of signals and timing diagrams, refer to the application note *Interfacing ISPI 160x to Hitachi SH7709 RISC Processor*.

In this configuration, ISP1160x is selected by CSB0# signal, which is asserted according to the values programmed in the *Chip Select Group Base Address* and *Chip Select registers* corresponding to CSB0#.

To correctly access ISP1160x, it is assumed that the area selected by CSB0# is programmed for the SRAM memory type and for 16-bit bus width accesses.

Interrupts INT are connected to the IRQ2 line of the DragonBall EZ processor. The interrupt inputs of the DragonBall EZ processor can be set as edge or level sensitive and of positive or negative polarity by programming its *Interrupt Control* register. ISP1160x also allows programming the polarity (LOW or HIGH) and the signaling mode (level or pulse) for generated interrupts INT, by setting the bits of the *HcHardwareConfiguration* register of the Host Controller. This ISP1160x feature allows a simple connection of the IRQ line, without any additional logic. The interrupts of the DragonBall processor can be masked in the *Interrupt Mask* register. Checking the status of an interrupt line can be done by monitoring the values of the *Interrupt Status* register and the *Interrupt Pending* register of the DragonBall-EZ processor.

Analysis of the timing diagrams of ISPI 160x and the DragonBall-EZ processor, running at a standard frequency of 16 MHz, shows that inserting wait states in a standard bus cycle is unnecessary. If a similar RISC processor with a higher bus frequency is used, you can insert wait-states during a bus cycle (accessing a certain system resource selected by CSn) by specifying the number of wait states in the corresponding (*Chip-Select*) *n* register of the DragonBall processor.

ISPI160x uses the input signals  $\overline{H_OC1}$  and  $\overline{H_OC2}$  to detect an overcurrent on the downstream facing ports. Because separate overcurrent detection and protection circuits are implemented in ISPI160x, so when an overcurrent is detected on a downstream port, power will be turned off at that port only. Connecting the voltages of the two downstream ports VBUS\_DN1 and VBUS\_DN2 to the  $\overline{H_OC1}$  and  $\overline{H_OC2}$  pins enables current to be detected by sensing the voltage drop on Q1 and Q2 which are MOSFET transistors with very low switch-on resistance Rds. Choose Q1 or Q2, depending on the maximum current you want, which in turn determines the value of Rds(on). For example, if a voltage drop of 75 mV will trigger the overcurrent circuitry and the allowed maximum current is about 0.5 A, Rds (on) of approximately 150 M $\Omega$  will result. Connecting the ISPI160x input pins  $\overline{H_OC1}$  and  $\overline{H_OC2}$  to +5 V will disable ISPI160x's internal overcurrent protection. You can opt for an external overcurrent protection circuit.

The  $\overline{\text{RESET}}$  input signal of ISP1160x is connected to the system RESET signal, which also generates the RESET# input signal for the DragonBall-EZ processor.



#### 8. References

- Universal Serial Bus Specification Rev. 2.0
- ISP1160 Embedded Universal Serial Bus Host Controller datasheet
- ISP1160A1 Embedded Universal Serial Bus Host Controller datasheet
- Interfacing ISP1160x to Hitachi SH7709 RISC Processor application note.

#### **Philips Semiconductors**

Philips Semiconductors is a worldwide company with over 100 sales offices in more than 50 countries. For a complete up-to-date list of our sales offices please e-mail

sales.addresses@www.semiconductors.philips.com.

A complete list will be sent to you automatically.

You can also visit our website

http://www.semiconductors.philips.com/sales/



#### © Koninklijke Philips Electronics N.V. 2003

All rights reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner. The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey or imply any license under patent – or other industrial or intellectual property rights.

